<template>
    <div class="addEdit-block">
        <el-form class="detail-form-content" ref="ruleForm" :model="ruleForm" :rules="rules" label-width="80px"
            :style="{ backgroundColor: addEditForm.addEditBoxColor }">
            <el-row>
                
        
                <input id="updateId" name="id" type="hidden">
                <input id="shangjiaId" name="shangjiaId" type="hidden">
                <el-col :span="12">
                    <el-form-item class="input" v-if="type != 'info'" label="商品名称" prop="shangpinName">
                        <el-input v-model="ruleForm.shangpinName" placeholder="商品名称" clearable
                            :readonly="ro.shangpinName"></el-input>
                    </el-form-item>
                    <div v-else>
                        <el-form-item class="input" label="商品名称" prop="shangpinName">
                            <el-input v-model="ruleForm.shangpinName" placeholder="商品名称" readonly></el-input>
                        </el-form-item>
                    </div>
                </el-col>
                <el-col :span="24">
                    <el-form-item class="upload" v-if="type != 'info' && !ro.shangpinPhoto" label="商品照片"
                        prop="shangpinPhoto">
                        <file-upload tip="点击上传商品照片" action="file/upload" :limit="3" :multiple="true"
                            :fileUrls="ruleForm.shangpinPhoto ? ruleForm.shangpinPhoto : ''"
                            @change="shangpinPhotoUploadChange"></file-upload>
                    </el-form-item>
                    <div v-else>
                        <el-form-item v-if="ruleForm.shangpinPhoto" label="商品照片" prop="shangpinPhoto">
                            <img style="margin-right:20px;" v-bind:key="index"
                                v-for="(item, index) in (ruleForm.shangpinPhoto || '').split(',')" :src="item"
                                width="100" height="100">
                        </el-form-item>
                    </div>
                </el-col>
                <el-col :span="12">
                    <el-form-item class="select" v-if="type != 'info'" label="商品类型" prop="shangpinTypes">
                        <el-select v-model="ruleForm.shangpinTypes" :disabled="ro.shangpinTypes" placeholder="请选择商品类型">
                            <el-option v-for="(item, index) in shangpinTypesOptions" v-bind:key="item.codeIndex"
                                :label="item.indexName" :value="item.codeIndex">
                            </el-option>
                        </el-select>
                    </el-form-item>
                    <div v-else>
                        <el-form-item class="input" label="商品类型" prop="shangpinValue">
                            <el-input v-model="ruleForm.shangpinValue" placeholder="商品类型" readonly></el-input>
                        </el-form-item>
                    </div>
                </el-col>
                <el-col :span="12">
                    <el-form-item class="input" v-if="type != 'info'" label="商品库存" prop="shangpinKucunNumber">
                        <el-input v-model="ruleForm.shangpinKucunNumber" placeholder="商品库存" clearable
                            :readonly="ro.shangpinKucunNumber"></el-input>
                    </el-form-item>
                    <div v-else>
                        <el-form-item class="input" label="商品库存" prop="shangpinKucunNumber">
                            <el-input v-model="ruleForm.shangpinKucunNumber" placeholder="商品库存" readonly></el-input>
                        </el-form-item>
                    </div>
                </el-col>
                <el-col :span="12">
                    <el-form-item class="input" v-if="type != 'info'" label="商品原价" prop="shangpinOldMoney">
                        <el-input v-model="ruleForm.shangpinOldMoney" placeholder="商品原价" clearable
                            :readonly="ro.shangpinOldMoney"></el-input>
                    </el-form-item>
                    <div v-else>
                        <el-form-item class="input" label="商品原价" prop="shangpinOldMoney">
                            <el-input v-model="ruleForm.shangpinOldMoney" placeholder="商品原价" readonly></el-input>
                        </el-form-item>
                    </div>
                </el-col>
                <el-col :span="12">
                    <el-form-item class="input" v-if="type != 'info'" label="现价" prop="shangpinNewMoney">
                        <el-input v-model="ruleForm.shangpinNewMoney" placeholder="现价" clearable
                            :readonly="ro.shangpinNewMoney"></el-input>
                    </el-form-item>
                    <div v-else>
                        <el-form-item class="input" label="现价" prop="shangpinNewMoney">
                            <el-input v-model="ruleForm.shangpinNewMoney" placeholder="现价" readonly></el-input>
                        </el-form-item>
                    </div>
                </el-col>
                <el-col :span="24">
                    <el-form-item v-if="type != 'info'" label="商品简介" prop="shangpinContent">
                        <editor style="min-width: 200px; max-width: 600px;" v-model="ruleForm.shangpinContent"
                            class="editor" action="file/upload">
                        </editor>
                    </el-form-item>
                    <div v-else>
                        <el-form-item v-if="ruleForm.shangpinContent" label="商品简介" prop="shangpinContent">
                            <span v-html="ruleForm.shangpinContent"></span>
                        </el-form-item>
                    </div>
                </el-col>
            </el-row>
            <el-form-item class="btn">
                <el-button v-if="type != 'info'" type="primary" class="btn-success" @click="onSubmit">提交</el-button>
                <el-button v-if="type != 'info'" class="btn-close" @click="back()">取消</el-button>
                <el-button v-if="type == 'info'" class="btn-close" @click="back()">返回</el-button>
            </el-form-item>
        </el-form>
    </div>
</template>
<script>
import styleJs from "../../../utils/style.js";
// 数字，邮件，手机，url，身份证校验
import { isNumber, isIntNumer, isEmail, isPhone, isMobile, isURL, checkIdCard } from "@/utils/validate";
export default {
    data() {
        return {
            addEditForm: null,
            id: '',
            type: '',
            sessionTable: "",//登录账户所在表名
            role: "",//权限
            userId: "",//当前登录人的id
            shangjiaForm: {},
            ro: {
                shangjiaId: false,
                shangpinName: false,
                shangpinPhoto: false,
                shangpinTypes: false,
                shangpinKucunNumber: false,
                shangpinOldMoney: false,
                shangpinNewMoney: false,
                shangpinClicknum: false,
                shangxiaTypes: false,
                shangpinDelete: false,
                shangpinContent: false,
            },
            ruleForm: {
                shangjiaId: '',
                shangpinName: '',
                shangpinPhoto: '',
                shangpinTypes: '',
                shangpinKucunNumber: '',
                shangpinOldMoney: '',
                shangpinNewMoney: '',
                shangpinClicknum: '',
                shangxiaTypes: '',
                shangpinDelete: '',
                shangpinContent: '',
            },
            shangpinTypesOptions: [],
            shangxiaTypesOptions: [],
            rules: {
                shangjiaId: [
                    { required: true, message: '商家不能为空', trigger: 'blur' },
                    {
                        pattern: /^[1-9][0-9]*$/,
                        message: '只允许输入整数',
                        trigger: 'blur'
                    }
                ],
                shangpinName: [
                    { required: true, message: '商品名称不能为空', trigger: 'blur' },
                ],
                shangpinPhoto: [
                    { required: true, message: '商品照片不能为空', trigger: 'blur' },
                ],
                shangpinTypes: [
                    { required: true, message: '商品类型不能为空', trigger: 'blur' },
                    {
                        pattern: /^[1-9][0-9]*$/,
                        message: '只允许输入整数',
                        trigger: 'blur'
                    }
                ],
                shangpinKucunNumber: [
                    { required: true, message: '商品库存不能为空', trigger: 'blur' },
                    {
                        pattern: /^[1-9][0-9]*$/,
                        message: '只允许输入整数',
                        trigger: 'blur'
                    }
                ],
                shangpinOldMoney: [
                    { required: true, message: '商品原价不能为空', trigger: 'blur' },
                    {
                        pattern: /^[0-9]{0,6}(\.[0-9]{1,2})?$/,
                        message: '只允许输入整数6位,小数2位的数字',
                        trigger: 'blur'
                    }
                ],
                shangpinNewMoney: [
                    { required: true, message: '现价不能为空', trigger: 'blur' },
                    {
                        pattern: /^[0-9]{0,6}(\.[0-9]{1,2})?$/,
                        message: '只允许输入整数6位,小数2位的数字',
                        trigger: 'blur'
                    }
                ],
                shangpinClicknum: [
                    { required: true, message: '点击次数不能为空', trigger: 'blur' },
                    {
                        pattern: /^[1-9][0-9]*$/,
                        message: '只允许输入整数',
                        trigger: 'blur'
                    }
                ],
                shangxiaTypes: [
                    { required: true, message: '是否上架不能为空', trigger: 'blur' },
                    {
                        pattern: /^[1-9][0-9]*$/,
                        message: '只允许输入整数',
                        trigger: 'blur'
                    }
                ],
                shangpinDelete: [
                    { required: true, message: '逻辑删除不能为空', trigger: 'blur' },
                    {
                        pattern: /^[1-9][0-9]*$/,
                        message: '只允许输入整数',
                        trigger: 'blur'
                    }
                ],
                shangpinContent: [
                    { required: true, message: '商品简介不能为空', trigger: 'blur' },
                ],
            }
        };
    },
    props: ["parent"],
    computed: {
    },
    created() {
        //获取当前登录用户的信息
        this.sessionTable = this.$storage.get("sessionTable");
        this.role = this.$storage.get("role");
        this.userId = this.$storage.get("userId");

       
        this.addEditForm = styleJs.addStyle();
        this.addEditStyleChange()
        this.addEditUploadStyleChange()
        //获取下拉框信息
        this.$http({
            url: `dictionary/page?page=1&limit=100&sort=&order=&dicCode=shangpin_types`,
            method: "get"
        }).then(({ data }) => {
            if (data && data.code === 0) {
                this.shangpinTypesOptions = data.data.list;
            }
        });
        this.$http({
            url: `dictionary/page?page=1&limit=100&sort=&order=&dicCode=shangxia_types`,
            method: "get"
        }).then(({ data }) => {
            if (data && data.code === 0) {
                this.shangxiaTypesOptions = data.data.list;
            }
        });

        

    },
    mounted() {
    },
    methods: {
        // 下载
        download(file) {
            window.open(`${file}`)
        },
        // 初始化
        init(id, type) {
            if (id) {
                this.id = id;
                this.type = type;
            }
            if (this.type == 'info' || this.type == 'else') {
                this.info(id);
            }
            // 获取用户信息
            this.$http({
                url: `${this.$storage.get("sessionTable")}/session`,
                method: "get"
            }).then(({ data }) => {
                if (data && data.code === 0) {
                    var json = data.data;
                } else {
                    this.$message.error(data.msg);
                }
            });
        },
        
        // 多级联动参数
        info(id) {
            let _this = this;
            _this.$http({
                url: `shangpin/info/${id}`,
                method: 'get'
            }).then(({ data }) => {
                if (data && data.code === 0) {
                    _this.ruleForm = data.data;
                } else {
                    _this.$message.error(data.msg);
                }
            });
        },
        // 提交
        onSubmit() {
            this.$refs["ruleForm"].validate(valid => {
                if (valid) {
                    this.$http({
                        url: `shangpin/${!this.ruleForm.id ? "save" : "update"}`,
                        method: "post",
                        data: this.ruleForm
                    }).then(({ data }) => {
                        if (data && data.code === 0) {
                            this.$message({
                                message: "操作成功",
                                type: "success",
                                duration: 1500,
                                onClose: () => {
                                    this.parent.showFlag = true;
                                    this.parent.addOrUpdateFlag = false;
                                    this.parent.shangpinCrossAddOrUpdateFlag = false;
                                    this.parent.search();
                                    this.parent.contentStyleChange();
                                }
                            });
                        } else {
                            this.$message.error(data.msg);
                        }
                    });
                }
            });
        },
        // 获取uuid
        getUUID() {
            return new Date().getTime();
        },
        // 返回
        back() {
            this.parent.showFlag = true;
            this.parent.addOrUpdateFlag = false;
            this.parent.shangpinCrossAddOrUpdateFlag = false;
            this.parent.contentStyleChange();
        },
        //图片
        shangpinPhotoUploadChange(fileUrls) {
            this.ruleForm.shangpinPhoto = fileUrls;
            this.addEditUploadStyleChange()
        },

        addEditStyleChange() {
            this.$nextTick(() => {
                // input
                document.querySelectorAll('.addEdit-block .input .el-input__inner').forEach(el => {
                    el.style.height = this.addEditForm.inputHeight
                    el.style.color = this.addEditForm.inputFontColor
                    el.style.fontSize = this.addEditForm.inputFontSize
                    el.style.borderWidth = this.addEditForm.inputBorderWidth
                    el.style.borderStyle = this.addEditForm.inputBorderStyle
                    el.style.borderColor = this.addEditForm.inputBorderColor
                    el.style.borderRadius = this.addEditForm.inputBorderRadius
                    el.style.backgroundColor = this.addEditForm.inputBgColor
                })
                document.querySelectorAll('.addEdit-block .input .el-form-item__label').forEach(el => {
                    el.style.lineHeight = this.addEditForm.inputHeight
                    el.style.color = this.addEditForm.inputLableColor
                    el.style.fontSize = this.addEditForm.inputLableFontSize
                })
                // select
                document.querySelectorAll('.addEdit-block .select .el-input__inner').forEach(el => {
                    el.style.height = this.addEditForm.selectHeight
                    el.style.color = this.addEditForm.selectFontColor
                    el.style.fontSize = this.addEditForm.selectFontSize
                    el.style.borderWidth = this.addEditForm.selectBorderWidth
                    el.style.borderStyle = this.addEditForm.selectBorderStyle
                    el.style.borderColor = this.addEditForm.selectBorderColor
                    el.style.borderRadius = this.addEditForm.selectBorderRadius
                    el.style.backgroundColor = this.addEditForm.selectBgColor
                })
                document.querySelectorAll('.addEdit-block .select .el-form-item__label').forEach(el => {
                    el.style.lineHeight = this.addEditForm.selectHeight
                    el.style.color = this.addEditForm.selectLableColor
                    el.style.fontSize = this.addEditForm.selectLableFontSize
                })
                document.querySelectorAll('.addEdit-block .select .el-select__caret').forEach(el => {
                    el.style.color = this.addEditForm.selectIconFontColor
                    el.style.fontSize = this.addEditForm.selectIconFontSize
                })
                // date
                document.querySelectorAll('.addEdit-block .date .el-input__inner').forEach(el => {
                    el.style.height = this.addEditForm.dateHeight
                    el.style.color = this.addEditForm.dateFontColor
                    el.style.fontSize = this.addEditForm.dateFontSize
                    el.style.borderWidth = this.addEditForm.dateBorderWidth
                    el.style.borderStyle = this.addEditForm.dateBorderStyle
                    el.style.borderColor = this.addEditForm.dateBorderColor
                    el.style.borderRadius = this.addEditForm.dateBorderRadius
                    el.style.backgroundColor = this.addEditForm.dateBgColor
                })
                document.querySelectorAll('.addEdit-block .date .el-form-item__label').forEach(el => {
                    el.style.lineHeight = this.addEditForm.dateHeight
                    el.style.color = this.addEditForm.dateLableColor
                    el.style.fontSize = this.addEditForm.dateLableFontSize
                })
                document.querySelectorAll('.addEdit-block .date .el-input__icon').forEach(el => {
                    el.style.color = this.addEditForm.dateIconFontColor
                    el.style.fontSize = this.addEditForm.dateIconFontSize
                    el.style.lineHeight = this.addEditForm.dateHeight
                })
                // upload
                let iconLineHeight = parseInt(this.addEditForm.uploadHeight) - parseInt(this.addEditForm.uploadBorderWidth) * 2 + 'px'
                document.querySelectorAll('.addEdit-block .upload .el-upload--picture-card').forEach(el => {
                    el.style.width = this.addEditForm.uploadHeight
                    el.style.height = this.addEditForm.uploadHeight
                    el.style.borderWidth = this.addEditForm.uploadBorderWidth
                    el.style.borderStyle = this.addEditForm.uploadBorderStyle
                    el.style.borderColor = this.addEditForm.uploadBorderColor
                    el.style.borderRadius = this.addEditForm.uploadBorderRadius
                    el.style.backgroundColor = this.addEditForm.uploadBgColor
                })
                document.querySelectorAll('.addEdit-block .upload .el-form-item__label').forEach(el => {
                    el.style.lineHeight = this.addEditForm.uploadHeight
                    el.style.color = this.addEditForm.uploadLableColor
                    el.style.fontSize = this.addEditForm.uploadLableFontSize
                })
                document.querySelectorAll('.addEdit-block .upload .el-icon-plus').forEach(el => {
                    el.style.color = this.addEditForm.uploadIconFontColor
                    el.style.fontSize = this.addEditForm.uploadIconFontSize
                    el.style.lineHeight = iconLineHeight
                    el.style.display = 'block'
                })
                // 多文本输入框
                document.querySelectorAll('.addEdit-block .textarea .el-textarea__inner').forEach(el => {
                    el.style.height = this.addEditForm.textareaHeight
                    el.style.color = this.addEditForm.textareaFontColor
                    el.style.fontSize = this.addEditForm.textareaFontSize
                    el.style.borderWidth = this.addEditForm.textareaBorderWidth
                    el.style.borderStyle = this.addEditForm.textareaBorderStyle
                    el.style.borderColor = this.addEditForm.textareaBorderColor
                    el.style.borderRadius = this.addEditForm.textareaBorderRadius
                    el.style.backgroundColor = this.addEditForm.textareaBgColor
                })
                document.querySelectorAll('.addEdit-block .textarea .el-form-item__label').forEach(el => {
                    // el.style.lineHeight = this.addEditForm.textareaHeight
                    el.style.color = this.addEditForm.textareaLableColor
                    el.style.fontSize = this.addEditForm.textareaLableFontSize
                })
                // 保存
                document.querySelectorAll('.addEdit-block .btn .btn-success').forEach(el => {
                    el.style.width = this.addEditForm.btnSaveWidth
                    el.style.height = this.addEditForm.btnSaveHeight
                    el.style.color = this.addEditForm.btnSaveFontColor
                    el.style.fontSize = this.addEditForm.btnSaveFontSize
                    el.style.borderWidth = this.addEditForm.btnSaveBorderWidth
                    el.style.borderStyle = this.addEditForm.btnSaveBorderStyle
                    el.style.borderColor = this.addEditForm.btnSaveBorderColor
                    el.style.borderRadius = this.addEditForm.btnSaveBorderRadius
                    el.style.backgroundColor = this.addEditForm.btnSaveBgColor
                })
                // 返回
                document.querySelectorAll('.addEdit-block .btn .btn-close').forEach(el => {
                    el.style.width = this.addEditForm.btnCancelWidth
                    el.style.height = this.addEditForm.btnCancelHeight
                    el.style.color = this.addEditForm.btnCancelFontColor
                    el.style.fontSize = this.addEditForm.btnCancelFontSize
                    el.style.borderWidth = this.addEditForm.btnCancelBorderWidth
                    el.style.borderStyle = this.addEditForm.btnCancelBorderStyle
                    el.style.borderColor = this.addEditForm.btnCancelBorderColor
                    el.style.borderRadius = this.addEditForm.btnCancelBorderRadius
                    el.style.backgroundColor = this.addEditForm.btnCancelBgColor
                })
            })
        },
        addEditUploadStyleChange() {
            this.$nextTick(() => {
                document.querySelectorAll('.addEdit-block .upload .el-upload-list--picture-card .el-upload-list__item').forEach(el => {
                    el.style.width = this.addEditForm.uploadHeight
                    el.style.height = this.addEditForm.uploadHeight
                    el.style.borderWidth = this.addEditForm.uploadBorderWidth
                    el.style.borderStyle = this.addEditForm.uploadBorderStyle
                    el.style.borderColor = this.addEditForm.uploadBorderColor
                    el.style.borderRadius = this.addEditForm.uploadBorderRadius
                    el.style.backgroundColor = this.addEditForm.uploadBgColor
                })
            })
        },
    }
};
</script>
<style lang="scss">
.editor {
    height: 500px;

    & /deep/ .ql-container {
        height: 310px;
    }
}

.amap-wrapper {
    width: 100%;
    height: 500px;
}

.search-box {
    position: absolute;
}

.addEdit-block {
    margin: -10px;
}

.detail-form-content {
    padding: 12px;
}

.btn .el-button {
    padding: 0;
}
</style>
